// eslint.config.js
import eslint from "@eslint/js"; // ESlint提供的现成的规则集
import globals from "globals";
import tseslint from "typescript-eslint";
import eslintPluginVue from "eslint-plugin-vue";
import stylistic from "@stylistic/eslint-plugin";
import eslintPluginPrettierRecommended from "eslint-plugin-prettier/recommended";

import js from "@eslint/js";

export default [
  {
    ignores: ["node_modules", "dist", "public"]
  },
  js.configs.recommended,
  {
    languageOptions: {
      globals: {
        ...globals.node // 启用 Node.js 全局变量（包括 `module`）
      }
    },
    files: ["**/*.cjs"], // 针对 .cjs 文件
    rules: {
      "no-undef": "off" // 关闭未定义检查（因为 CommonJS 的 `module` 是合法的）
    }
  },
  eslint.configs.recommended,
  /** ts推荐配置 */
  ...tseslint.configs.recommended,
  /** vue推荐配置 */
  ...eslintPluginVue.configs["flat/recommended"],

  stylistic.configs.customize({
    indent: 2,
    quotes: "single",
    semi: false,
    jsx: true,
    braceStyle: "1tbs",
    arrowParens: "always"
  }),

  /**
   * javascript 规则
   */
  {
    files: ["**/*.{js,mjs,cjs,vue}"]
  },

  /**
   * 配置全局变量
   */
  {
    languageOptions: {
      globals: {
        ...globals.browser,
        /** 追加一些其他自定义全局规则 */
        wx: true
      }
    }
  },

  /**
   * vue 规则
   */
  {
    files: ["**/*.vue"],
    languageOptions: {
      parserOptions: {
        /** typescript项目需要用到这个 */
        parser: tseslint.parser,
        ecmaVersion: "latest",
        /** 允许在.vue 文件中使用 JSX */
        ecmaFeatures: {
          jsx: true
        }
      }
    },
    rules: {
      // 在这里追加 vue 规则
      "vue/no-mutating-props": [
        "error",
        {
          shallowOnly: true
        }
      ]
    }
  },

  /**
   * typescript 规则
   */
  {
    files: ["**/*.{ts,tsx,vue}"],
    rules: {
      "no-undef": "off" // 关闭未定义检查（由 TypeScript 接管类型检查）
    }
  },
  {
    rules: {
      // eslint (http://eslint.cn/docs/rules)
      "no-var": "error", // 要求使用 let 或 const 而不是 var
      "no-multiple-empty-lines": ["error", { max: 1 }], // 不允许多个空行
      "prefer-const": "off", // 使用 let 关键字声明但在初始分配后从未重新分配的变量，要求使用 const
      "no-use-before-define": "off", // 禁止在 函数/类/变量 定义之前使用它们

      // typeScript (https://typescript-eslint.io/rules)
      "@typescript-eslint/no-unused-vars": [
        "warn",
        {
          args: "none", // 禁止未使用的参数
          varsIgnorePattern: "^_" // 忽略以 _ 开头的变量
        }
      ],
      // "@typescript-eslint/no-unused-vars": "warn", // 禁止定义未使用的变量
      "@typescript-eslint/no-empty-function": "warn", // 禁止空函数
      "@typescript-eslint/prefer-ts-expect-error": "error", // 禁止使用 @ts-ignore
      "@typescript-eslint/ban-ts-comment": "error", // 禁止 @ts-<directive> 使用注释或要求在指令后进行描述
      "@typescript-eslint/no-inferrable-types": "off", // 可以轻松推断的显式类型可能会增加不必要的冗长
      "@typescript-eslint/no-namespace": "off", // 禁止使用自定义 TypeScript 模块和命名空间
      "@typescript-eslint/no-explicit-any": "off", // 禁止使用 any 类型
      "@typescript-eslint/ban-types": "off", // 禁止使用特定类型
      "@typescript-eslint/no-var-requires": "off", // 允许使用 require() 函数导入模块
      "@typescript-eslint/no-non-null-assertion": "off", // 不允许使用后缀运算符的非空断言(!)
      "@typescript-eslint/no-unused-expressions": "off", // 禁止未使用的表达式

      // vue (https://eslint.vuejs.org/rules)
      // 'vue/script-setup-uses-vars': 'error', // 防止<script setup>使用的变量<template>被标记为未使用，此规则仅在启用该 no-unused-vars 规则时有效
      "vue/v-slot-style": "error", // 强制执行 v-slot 指令样式
      "vue/no-mutating-props": "error", // 不允许改变组件 prop
      "vue/custom-event-name-casing": "error", // 为自定义事件名称强制使用特定大小写
      "vue/html-closing-bracket-newline": "error", // 在标签的右括号之前要求或禁止换行
      "vue/attribute-hyphenation": "off", // 对模板中的自定义组件强制执行属性命名样式：my-prop="prop"
      "vue/attributes-order": "off", // vue api使用顺序，强制执行属性顺序
      // "vue/no-v-html": "off", // 禁止使用 v-html
      "vue/require-default-prop": "off", // 此规则要求为每个 prop 为必填时，必须提供默认值
      "vue/multi-word-component-names": "off", // 要求组件名称始终为 “-” 链接的单词
      "vue/no-setup-props-destructure": "off" // 禁止解构 props 传递给 setup
    }
  },
  /**
   * prettier 配置
   * 会合并根目录下的prettier.config.js 文件
   * @see https://prettier.io/docs/en/options
   */
  eslintPluginPrettierRecommended
];
